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Enhanced Intel® SpeedStep® Technofogy for the Intel® Pentium® M Processor 



1.0 Introduction 

Enhanced Intel* SpeedStep* Technology has revolutionized thermal and power management by giving 
application software greater control over the processor's operating frequency and input voltage. Systems 
can easily manage power consumption dynamically. This paper describes how this flexible power 
management scheme is implemented and how designers can best integrate this technology into their current 
or next-generation board design. 

Today's embedded systems are demanding greater performance at equivalent levels of power consumption. 
Legacy hardware support for backplanes, board sizes and thermal solutions have forced design teams to 
place greater emphasis on power and thermal budgets. Intel has extended architectural innovation for 
saving power by implementing new features such as Enhanced Intel SpeedStep Technology. 

Enhanced Intel SpeedStep Technology allows the processor performance and power consumption levels to 
be modified while a system is functioning. This is accomplished via application software, which changes 
the bus-to-core frequency ratio and the processor core voltage (Vcc). A variety of inputs such as system 
power source, processor thermal state, or operating system policy are used to determine the proper 
operating state. 

The software model behind Enhanced Intel SpeedStep Technology has ultimate control over the frequency 
and voltage transitions. This software model is a major step forward over previous implementations of Intel 
SpeedStep technology. Legacy versions of Intel SpeedStep technology required hardware support through 
the chipset. Enhanced Intel SpeedStep Technology has removed the chipset hardware requirement and only 
requires the support of the voltage regulator, processor and operating system. Centralization of the control 
mechanism and software interface to the processor, and reduced hardware overhead has reduced processor 
core unavailability time to 10 jis from the previous generation unavailability of 250 u.s. 

2.0 Processor Support 

Enhanced Intel SpeedStep Technology is supported on current and future generations of Intel 15 Pentium* M 
Processors. The Intel Pentium M Processor at 1.6 GHz supports six frequency and voltage operating points. 

Table 1.1 Supported Perform ance States for the Intel® Pentium ® M Processor at 1.6GHz 1 







1.6 GHz (HFM) 


1.484 V 


1.4 GHz 


1.420 V 


1.2 GHz 


1.276 V 


1.0 GHz 


1.164 V 


800 MHz 


1.036 V 


600 MHz(LFM) 


0.956 V 



The top and bottom modes are commonly known as high frequency mode (HFM) and low frequency mode 
(LFM). These frequency and voltage operating points are stored within a read-only processor model 
specific register (MSR). This MSR ensures BIOS will not allow transitions to invalid states above the HFM 
maximum or below the LFM minimum. The other four operating points are stored within BIOS code, as a 
drop in voltage table provided by Intel to BIOS vendors. 
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3.0 Thermal Design Power 

The Intel power specification for components is known as Thermal Design Power, or TDP. The TDP value, 
along with the maximum junction temperature, defines Inters recommended design point for thermal 
solution capability. For the Intel 10 Pentium 15 M Processor, which supports Enhanced Intel SpeedStep 
Technology, Intel will specify the TDP for both the HFM and LFM operating states. These TDP values are 
specified in the Intel' 10 Pentium® M Processor Datasheet and also shown in the following table for the 1.6 
GHz and 1.1 GHz parts. 

Table 1.2 HFM and LFM Thermal Design Power Points for the Intel® Pentium® M Processor at 
1.6 GHz 1 







mommmmm 


HFM 


1.6GHz 


24.5 W 


LFM 


600MHz 


6W 




Table 1.3 HFM and LFM Thermal Design Power Points for the Low Voltage Intel® Pentium® M 
Processor at 1.1 GHz 1 









HFM 


1.1GHz 


12 W 


LFM 


600MHz 


6W 



Between the HFM and LFM frequency/voltage points, the dissipated power will be approximately 
proportional to the square of the voltage, due to Ohm's Law. 

Equation 1.1 Ohm's Law, where P=Power, C=Capacltance, V=Voltage, and F=Frequency 

P = CV 2 F 
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Figure 1.1 Power vs. Core Voltage for the Intel® Pentium® M Processor at 1.6GHz for Its six 
frequency/voltage operating points (not to scale). HFM and LFM power values are 
TDP specifications. 
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4.0 Implementation 

All Intel Pentium M processors have support for Enhanced Intel SpeedStep Technology. This can be 
. verified by checking the ECX feature bit 07 in the CPU ID register. Enhanced Intel SpeedStep Technology 
is enabled by setting the IA32_MISC_ENABLE MSR, bit 16. This bit should be written by the system 
BIOS upon boot 

Processor frequency/voltage transitions are initiated by writing a 16-bit value to the IA32PERFCTL 
register. If a transition is already in progress, transition to a new value will take effect subsequently. Reads 
of the IA32_PERF_CTL register determine the last targeted operating point. The current operating point 
can be read from IA32_PERF_STATUS register, which is updated dynamically. 

The 16-bit encoding defining valid operating points is model-specific and Intel proprietary. See your Intel 
representative to obtain documentation outlining the required encoding. 

By centralizing the implementation of Enhanced Intel SpeedStep Technology to the processor, software can 
perform a frequency/voltage operating state transition by simply writing to one register 
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Table 1.4 Enhanced Intel® SpeedStep® Technology MSRs 





- \ . .:. V 1 - - • 1: . . w ; ... . . 


^DefmitiooyUsage^^ : ' ' - : V : " \[ T : l : ' 

<.*. .. v i » ...... „ , . 






1A0 


416 


IA32JV1ISC_ENABLE 


Enable Miscellaneous Processor Features. Bit 16 
must be set to a 1 in order to implement Enhanced 
Intel® SpeedStep® Technology features. 


199H 


409 


IA32_PERF_CTL 


Bits 15:0 indicate the target frequency and voltage 
operating point. 


198H 


408 


IA32_PERF_STATUS 


Bits 1 5:0 indicate the current frequency and voltage 
operating point. 



5.0 Software Considerations 

As already noted, the software model behind Enhanced Intel SpeedStep Technology performs all 
management for the frequency and voltage transitions. Microsoft* Windows* XP and the Windows Server 
2003 family include complete native processor performance control to support this functionality. 

The native support in Windows XP and the Windows Server 2003 family consists of two components: the 
kernel power policy manager and the processor driver. The kernel power policy manager owns the 
decision-making and the set of rules used to determine the appropriate frequency/voltage operating state. It 
may make decisions based on several inputs, such as end-user power policy, processor utilization, battery 
level, or thermal conditions and events. The processor driver is used to make actual state transitions on the 
kernel power policy manager's behalf. The driver does not initiate frequency/voltage state transitions 
independent of the kernel power policy manager. 
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Figure 1.2 Software Model for Windows XP and Windows Server 2003 
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End-user power policy inputs are entered via the "Power Options" icon within the Control Panel. Based on 
the selected policy, Windows will adjust its decision-making for power states accordingly. 

policy 



Table 1.5 Relationship between power policy scheme and processor dynamic throttling 


|ifc^frJ^^^P^@f^|^|^|f| 


/ACT^pwer * 'Will 1 


DC Power 


Home/Office Desk 


None 


Adaptive 


Portable/Laptop 


Adaptive 


Adaptive 


Presentation 


Adaptive 


Degrade 


Always On 


None 


None 


Minimal Power Management 


Adaptive 


Adaptive 


Max Battery 


Adaptive 


Degrade 



The processor dynamic throttle policy has been defined to operate in one of four states: None, Adaptive, 
Constant, and Degrade. "None" will ensure the processor is always at the highest performance state 
currently available, barring any unique thermal conditions where hardware will force a lower state. 
"Adaptive" matches the performance state to current demand. "Constant" will run the processor in the 
lowest available frequency/voltage state. Similar to the constant slate, "Degrade" will always run the 
processor in the lowest available frequency/voltage state. Furthermore, this policy state will utilize linear 
stop clock throttling if the remaining battery capacity drops below a certain threshold 

Apart from Windows XP and the Windows Server 2003 family, support also exists from Intel and 
Microsoft for Enhanced Intel SpeedStep Technology transitions on legacy Microsoft platforms. Legacy 
versions of the Windows operating system do not include complete power policy manager and driver 
support. Thus, Intel has released an Enhanced Intel SpeedStep Technology Applet specifically to enable 
this functionality on the following versions of Windows: 
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Microsoft Windows 2000 

Microsoft Windows 98 SE 

Microsoft Windows Millennium Edition (ME) 

Microsoft Windows NT 4.0 

This applel is available from either Intel or an Intel OEM. See your Intel representative for more 
information or to order the Enhanced Intel SpeedStep Technology Applet. 

The Enhanced Intel SpeedStep Technology Applet provides both a power policy and a driver to enable 
dynamic transitions. The end user policy is again established through the Windows Control Panel, with 
very similar power state operation. 

Figure 1 .3 Software Model for the Enhanced Intel® SpeedStep® Technology Applet on Legacy 
Windows Platforms 
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Notice the software model for legacy Windows platforms must use system management mode, which 
creates slightly more overhead on the system. A detailed overview of system management mode (SMM) 
may be found in the lA-32 Intel* Architecture Software Developer \s Manual. 

Support for operating systems other than Microsoft Windows is available to varying degrees in the Linux 
open source community. Linux operating systems with support for ACPI 2.0 may enable performance state 
transitions by manually writing to the appropriate file (e.g., /proc/cpufreq or /proc/acpi/processor). Linux 
kernel version 2.6 and newer provides mil ACPI support and maps Enhanced Intel SpeedStep Technology 
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MSRs to the correct object table (see Table 1.7). Although support may exist for manual performance state 
changes through ACPI object tables, automatic performance state change based on thermal conditions, 
battery life, or other user parameters is limited and dependent on operating system vendor. More 
information may be found at Intel's Instantly Available Technology website at 
hUn://developer.intel.com/technologv/iapc/acpi/ . 

6.0 ACPI Considerations 

ACPI, or Advanced Configuration and Power Interface, has greatly simplified and standardized power 
system management. ACPI 2.0 has introduced new power states on a system, device, and processor level. 
This paper will introduce the processor power state levels (P-states), and map them to how Enhanced Intel 
SpeedStep Technology transitions are made. Other power states, such as C-states, S-states, and D-states are 
covered in the ACPI 2.0 specification at www.acpi.info. 

Figure 1.4 Processor Performance States (P-states) Discussed Herein Are Sub-States of CO 




Processor P-states are defined as frequency/voltage operating states. Unlike other ACPI defined power 
states, such as C 1 , C2, etc., the processor is actually executing instructions in all P-states, since they are 
subslates of CO. P0 is defined as the maximum performance/highest power consuming state, which is also 
termed HFM on an Intel Pentium M Processor. PI, P2, ... Px-1, Px are defined with incrementally lower 
performance and power dissipation. 
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Table 1.6 P-States for the Intel® Pentium® M Processor at 1.6GHz 1 



KFr^iiericy 'P 


Voltage" : 


estate" " " 


1 .6 GHz 


1.484 V 


P0 


1.4 GHz 


1.420 V 


P1 


1.2 GHz 


1.276 V 


P2 


1.0 GHz 


1.164 V 


P3 


800 MHz 


1.036 V 


P4 


600 MHz 


0.956 V 


P5 



ACPI 2.0 provides a standard interface for operating systems to communicate with hardware. Specific 
component capabilities are mapped into ACPI 2.0 tables. 

Table 1 .7 ACPI Object Table Definitions 



:f &£p* 2$ Mbjec^Tafcie; u-^ 


:;H? a »®: :.- J : : : . : : : : :~: ; : ; :::::: ; : :r :::•<•::: 


_PCT 


Identifies location of I/O mapped MSRs for status and control 


_PSS 


Lists the possible processor frequency and voltage operating 
states 


_PPC 


Reflects the capabilities of the platform 



It is the responsibility of the BIOS to construct and fill-in the ACPI tables. Intel provides frequency/voltage 
tables or a BIOS algorithm to fill the _PSS object table. After the tables have been populated, the operating 
system may force performance state changes by accessing the MSRs via the corresponding ACPI object 
tables. 



7.0 Non-ACPI Implementations 

ACPI is recommended for designing systems that utilize Enhanced Intel SpeedStep Technology. Deeply 
embedded designs not utilizing the ACPI interface may still incorporate frequency and voltage transitions 
by directly reading and writing to the corresponding MSRs on the processor. The chosen frequency and 
voltage combinations MUST match the valid combinations as presented in the processor datasheet. Any 
other combinations will force the processor to operate outside of specification and may cause component 
failure. 

Centralizing implementation for real-time frequency/voltage transitions to a processor MSR has enabled 
deeply embedded operating systems and applications to easily change and control operating states. 
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8.0 Voltage Regulator Support 

Processors featuring Enhanced Intel SpeedStep Technology provide multiple VTD pins that are directly 
connected to voltage regulator. These VID pins signal the desired voltage for the processor. The pin output 
is mapped to a table, as listed in the corresponding processor datasheet. The corresponding voltage for the 
VTD output is subsequently provided to the core processor plane by the voltage regulator. 

Voltage regulator designs for the Intel Pentium M processor have been designed to accept core voltage 
inputs from 0.7 V to 1.708 V as selected by six VTD pins. This wide range of voltages allows one regulator 
design to support all processors within the Intel Pentium M and Intel* Celeron* M families, including low 
voltage and ultra low voltage versions. Additionally, all processors in this family are both package and pin 
footprint compatible. 




9.0 Conclusion 

Enhanced Intel SpeedStep Technology has revolutionized thermal and power management by centralizing 
hardware implementation to the processor. By also giving software greater control over the transition 
mechanism, performance state transitions may be dynamically controlled to manage increasingly tight 
power and thermal budgets. 
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Notes 

t. Please refer to the Intel* Pentium* M Processor Datasheet for the latest specifications. All information 
included in the datasheet supersedes the material of this document. 
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